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Comptons les moutons 


Champ de manœuvre 
Le Commodore Plus/4 


Contrôler la puissance 


Page manquante 
(publicité et colophon) 


Le i * 
Déplacements calculés 


Nous avons étudié les méthodes de déplacement des robots, puis 
la conception de leurs « bras » et « mains ». Maintenant, abordons 
la manière de les programmer pour des tâches « intelligentes ». 


Signe des temps 


Un bras de robot conçu 
pour tracer des signes 
montrerait une démarche 
continue et un processus 
point-à-point. Chaque mot 
tracé devrait l'être de 
manière continue sous la 
conduite d’un opérateur. 
Mais à la fin de chaque 
mot, le pinceau-écrivain 
aurait à passer du papier 
à l’encrier selon une 
progression point-à-point 
déterminée en fonction 
de sa position courante 
et de celle de l’encrier. 


(CI. Steve Cross.) 


L'idée d’un bras intelligent peut paraître, à pre- 
mière vue, illogique. La forme d’intelligence 
étudiée ici n’a rien à voir avec celle, ultra- 
sophistiquée, de l’homme. Prenons l’exemple 
d’un acte humain simple. Vous êtes assis à une 
table vide, à l’exception d’un petit objet situé à 
gauche que vous devez déplacer vers la droite. 
Deux formes d’intelligence sont ici en cause : la 
première implique la perception de la table, de 
l’objet et la décision de déplacer ce dernier de la 
gauche vers la droite. Cela suppose un certain 
degré de conscience et met en jeu des concepts 
tels que « intention » et « objectif ». L’intelli- 
gence dont nous avons besoin ici est d’un degré 
bien inférieur à celle qui est nécessaire pour 
déplacer votre bras et votre main une fois la déci- 
sion prise d’effectuer la tâche : déplacer votre 
main vers la droite et vous assurer qu’elle tient 
bien l’objet avant de le poser au bon moment. 


Entraînement humain 


Cela peut vous paraître à la fois facile et évident. 
Si vous doutez de l’intelligence dans cet acte, 
observez bien la manière de procéder d’un petit 
enfant : souvent il ne parviendra pas à saisir 
l’objet du premier coup, il le placera ailleurs que 
là où il doit aller, et, plus généralement, mani- 
festera une hésitation sur ce qui lui est demandé. 
L’enfant s’exerce à acquérir l’intelligence active 
nécessaire pour déplacer les bras et les mains dans 
un univers à trois dimensions qui lui est encore 
étranger. Lorsqu'il aura appris à maîtriser ses 
mouvements, ils lui paraîtront presque automa- 
tiques. Il cessera alors d’y penser et d’y associer 
un effort d’intelligence. Le bras du robot en reste 
au stade du petit enfant : il est équipé pour la 
tâche requise, mais il doit apprendre comment 
la réaliser automatiquement. 
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Géométrie à deux 
articulations 

En se déplaçant point-à- 
point, le bras à deux 
articulations doit 
effectuer une rotation sur 
son pivot (angle R), et 
modifier les angles des 
articulations de son 
épaule (E et de son 
coude (C). Si les 
coordonnées 
cartésiennes des points 
courants et de 
destination sont 

(,Y1,1) et (X2Y2,22, les 
modifications seront 
calculées de la manière 
suivante : 


A1=SORX1 © 2+ Y2*2+71"2) 
A2=SOR(X2 © 2+Y2°2+22° 2) 


Pivot 
R1=ARCTAN(Y1/X1) 
R2 = ARCTAN(Y2/X2) 
Modification = (R2 - R1) 


Épaule s 

S1=ARCCOS(Z1/A1) + ARCCOS 
(A1°1+B"2-AB°2) 
(2*A1‘B)) 

S2 = ARCCOS(Z2/A2) + ARCCOS 
(42° 2+B °2-AB ° 2} 
(2*A2'B)) 

Modification = (2 -S1) 


Coude 
E1=ARCCOS{(B * 2+AB * 2- 
A1 ” 2}(2*B*AB)) 
E2=ARCCOS((B * 2+AB * 2-A2 * 2) 
(2*B'AB)) 
Modification =(E1 - E2) 


où B représente la 
longueur du bras, et AB, 
celle de l’avant-bras. 
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La méthode la plus simple consiste à appren- 
dre au bras à réaliser des tâches spécifiques en 
le guidant tout au long d’une séquence de dépla- 
cements, et en le forçant pratiquement à s’en 
souvenir. Cette méthode est utilisée avec de nom- 
breux robots industriels. L'opérateur prend lit- 
téralement le robot par la main pour le guider à 
travers l’ensemble des étapes. Pour l’opérateur, 
l’avantage est manifeste, car il n’a pas besoin de 
savoir comment le bras articulé fonctionne. Il 
doit seulement savoir quelles séquences faire sui- 
vre au robot. De son côté, le robot n’a pas besoin 
de savoir ce qu’il fait, mais simplement de se sou- 
venir des tâches qu’il exécute. 


Méthodes d'entraînement 


Il existe deux types d’entraînement pour le 
robot : l’entraînement point par point, et l’entraî- 
nement global sur l’ensemble du parcours. Dans 
l’entraînement point par point, l’opérateur 
déplace le bras sur une certaine position et appuie 
sur un bouton pour signifier au robot qu’il doit 
se souvenir de cette position. Le bras est alors 
déplacé sur la position suivante, et le bouton 
enregistre la nouvelle position. La séquence se 
poursuit jusqu’à ce que toutes les étapes aient été 
enregistrées dans la mémoire du robot. Une fois 
cet entraînement terminé, le robot peut être com- 
muté en mode « playback », et il est alors à même 
de se déplacer d’un point à l’autre comme il l’a 
appris. Avec l’entraînement global, l’opérateur 
guide le robot à travers toute la séquence à sui- 
vre et le robot enregistre l’ensemble de la 
séquence. En mode retour {playback), le robot 
reprend toute la séquence. 

Pour revenir à notre exemple de l’objet à 
déplacer sur la table d’un côté à l’autre, nous 
pouvons utiliser la méthode d’entraînement point 


AXE DES Y 


par point. Cette méthode est souvent utilisée avec 
les robots qui doivent effectuer des tâches du type 
« prendre et transporter » — déplacer un objet 
d’un endroit à l’autre. En revanche, un robot des- 
tiné à peindre au pistolet suivra avantageusement 
la méthode globale qui évite les interruptions. 

Il nous faut maintenant envisager la manière 
dont le robot retient les séquences à suivre. Il 
enregistre, en fait, à l’aide de ses capteurs inter- 
nes, la position de toutes ses articulations pen- 
dant la phase d’entraînement. Cela est souvent 
réalisé en relevant le résultat en sortie des enco- 
deurs de transmission dans les articulations du 
robot et en enregistrant les mouvements effec- 
tués, soit directement en mémoire soit, pour des 
sauvegardes plus durables, sur bande ou sur dis- 
que. Lorsque le mode retour (playback) est sélec- 
tionné, le robot peut rappeler les données et les 
convertir en mouvements articulaires, ce qui est 
assez complexe. 

De manière surprenante, le robot a beaucoup 
de facilité à se souvenir d’un mouvement continu 
— il doit simplement suivre la route exacte qu’il 
a apprise. Il faut cependant sauvegarder un nom- 
bre considérable de données. Plusieurs centaines 
de positions sont souvent nécessaires pour une 
séquence, alors que quelques positions seulement 
suffisent pour mémoriser un mouvement « pas- 
à-pas ». La deuxième difficulté vient du fait que 
si le robot doit pouvoir effectuer le mouvement 
doucement et avec précision, il faut que ses arti- 
culations soient sollicitées simultanément. Un 
robot de peinture doit pouvoir déplacer son bras 
selon les trois axes, tout en manœuvrant les trois 
articulations terminales de son « poignet » pour 
diriger avec précision les jets de peinture. Cela 
signifie que l’ordinateur, qui dirige le robot, doit 
agir très vite pour actionner tour à tour les arti- 
culations, sans aucun décalage. Une solution 
consiste à mettre en œuvre simultanément 
jusqu’à six processeurs distincts, chacun ayant en 
charge une articulation et une seule, dans le but 
d’obtenir une simultanéité parfaite. 


Déplacement calculé 


Un robot pas-à-pas a la tâche plus rude. Bien 
qu’il sache où il doit aller, il ne sait pas comment 
y aller. Il serait possible de manœuvrer chaque 
articulation jusqu’à obtenir la position voulue, 
mais ce serait une perte de temps et d’énergie. Il 
serait de loin préférable pour le robot de calcu- 
ler sa route d’un point à l’autre : il pourrait alors 
effectuer son déplacement en un seul mouvement, 
à la façon d’une personne humaine. Mais les cal- 
culs sont aussi trop complexes, car les coordon- 
nées cartésiennes sont nécessaires pour déplacer 
la main en ligne droite d’un point à un autre. Les 
positions du bras sont en outre définies selon un 
système de coordonnées différentes, par exem- 
ple des coordonnées circulaires. C’est pourquoi 
le robot doit être à même de résoudre des pro- 
blèmes géométriques complexes pour fonction- 
ner de manière satisfaisante. Dans le cas de 
robots industriels déplaçant sur de grandes dis- 
tances des objets pesant plusieurs centaines de 


tonnes, le choix de la meilleure trajectoire per- 
met d'économiser de manière considérable du 
temps et de l’énergie. 

Un autre problème concernant le déplacement 
pas-à-pas est la dynamique même du mouvement. 
Si vous étendez votre bras pour saisir quelque 
chose, vous observerez qu’il se déplace lentement 
au départ, pour atteindre la vitesse maximale en 
milieu de course et ralentir doucement avant 
d’atteindre son but. Pour une telle tâche, les 
avantages d’un bras de robot sont considérables. 
Il peut parfaitement démarrer son mouvement à 
toute vitesse, maintenir cette vitesse maximale et 
s’arrêter net en fin de séquence. Une grande 
contrainte s’exerce sur le bras et suppose davan- 
tage de puissance que pour un bras qui accélère 
et freine doucement. Cela signifie également que 
le bras court un risque trop grand s’il doit, en 
fin de course, prendre un objet délicat. Un sim- 
ple déplacement malencontreux de l’objet à sai- 
sir est alors catastrophique. Le robot doit donc 
concilier vitesse optimale et trajectoire parfaite. 


Chorégraphie robotique 


Même lorsque le bras a été programmé pour sui- 
vre un ensemble précis de mouvements, il peut 
apparaître, lors de la répétition de la séquence, 
que les mouvements enregistrés ne correspondent 
pas tout à fait aux tâches demandées. Cela peut 
être dû à une erreur humaine, à un léger change- 
ment dans la nature du travail à effectuer, ou à 
un travail du robot fait en conjonction avec 
d’autres bras articulés (ses bras entrent alors en 
collision avec d’autres bras). La démarche qui 
permet d’éviter une telle situation s’appelle 
« chorégraphie robotique ». Il faut donc mettre 
au point une méthode pour éditer la séquence. 
Cela peut se faire en sauvegardant les mouve- 
ments sous la forme d’une liste de mouvements 
enchaînés, dans laquelle chaque position est sau- 
vegardée et suivie de l’adresse où l’on peut trou- 
ver la position suivante. Pour la séance initiale 
d’entraînement, cette adresse est celle de la posi- 
tion suivante dans la liste. Si la séquence doit être 
éditée, le bras peut être déplacé sur la position 
où des corrections doivent être faites, puis être 
arrêté de manière à ce qu’une nouvelle séquence 
soit insérée. 

Une autre méthode pour rendre les bras arti- 
culés plus intelligents est d’utiliser un ensemble 
d’instructions programmées stockées dans l’ordi- 
nateur. Pratiquement, chaque robot possède sa 
propre méthôde de programmation et met en 
œuvre un langage de programmation différent 
pour contrôler ses mouvements. Néanmoins, un 
langage est nécessaire pour que le programmeur 
puisse utiliser des commandes du genre LOGO afin 
de spécifier des déplacements dans trois dimen- 
sions et donner des instructions au « poignet » 
et à la « main », telles que « prendre ou « lâcher ». 

Le problème est semblable à celui de l’entraf- 
nement du robot en mode pas-à-pas, et de nom- 
breux facteurs sont à prendre en compte. Par 
exemple, si le bras doit avancer de 10 unités, la 
meilleure méthode est de modifier l’articulation 


de l’épaule, de sorte que le bras pourra aller plus 
loin. L’épaule doit alors se déplacer vers le haut 
selon un arc de cercle, et un déplacement com- 
pensateur vers le bas doit intervenir au niveau du 
coude. Nous voyons donc que cette instruction 
destinée à un simple mouvement doit se décom- 
poser en deux séquences distinctes d’instructions 
destinées à deux articulations différentes. 
D’autres problèmes se posent lorsque le bras 
doit prendre des objets. Aussi bien positionné que 
le bras puisse être, on peut difficilement être cer- 
tain qu’il est bien à même de saisir l’objet, sur- 
tout lorsque ce dernier est de forme asymétrique. 
Il faut donc pourvoir le bras d’une main intelli- 
gente. Celle-là devra sentir la présence ou 
l’absence de l’objet, la distance à laquelle il se 
trouve et la force qu’elle devra exercer lorsqu’elle 
essaiera de le prendre. Ces problèmes seront réso- 
lus en équipant la main de capteurs de proximité, 
de capteurs tactiles et de force. Ces capteurs ren- 
voient des informations sur l’action de la main 
(feedback) et permettent à l’ordinateur de 
contrôle d’effectuer les corrections nécessaires. 
En prenant en compte tous ces problèmes, il 
est possible de concevoir un robot doté d’un cer- 
tain degré d'intelligence. Néanmoins, aucun 
robot n’a encore pu être créé pour jouer au ten- 
nis, par exemple. La raison en est que l’intelli- 
gence du bras ne suffit pas. Le robot devrait, 
pour pouvoir rattraper une balle, en apprécier la 
direction, la hauteur, la force, et tenir compte 
d’une foule d’autres critères de positionnement, 
sans compter la résolution extrêmement complexe 
de problèmes de trajectoires. Pour cela, il faut 
beaucoup plus qu’un bras intelligent. 


RÉGLAGE 
DU SERRAGE 


CAPTEUR 
DE PROXIMITÉ 


CAPTEURS TACTILES 


Doucement... 

Faire prendre un œuf par 
un robot est un très bon 
test de recherche pour 
les capteurs et pour 
contrôler la rétroaction 
du bras. 

Le capteur de proximité 
de la pince doit vérifier 
que l'œuf est assez près; 
les mâchoires peuvent 
alors commencer à se 
resserrer jusqu'à ce que 
les capteurs du toucher 
indiquent le contact avec 
l'œuf. Le résultat en 
sortie des capteurs du 
toucher doit être 
comparé à celui du 
capteur de proximité, 
lorsque la pince se 
referme sur l'œuf et que 
le bras se lève. Une 
chute brutale de la 
proximité signifie que 
l'œuf est en train de 
s'échapper. Aussi les 
mâchoires doivent-elles 
se serrer jusqu'à 
atteindre une limite 
prédéterminée de 
serrage, ou jusqu'à ce 
qu'une chute soudaine de 
résistance indique que la 
coquille de l'œuf se 
déforme avant de casser. 
(CI. Steve Cross.) 
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BB 05 TOURS ORNE | 
Champ de manœuvre 


De simples programmes utilitaires peuvent être écrits entièrement 
en BASIC. Des programmes plus complexes comportant des détails 
nombreux doivent être écrits en langage machine. 


1184 


Pour faire fonctionner notre programme de 
recherche de variables, nous l’avons fusionné au 
programme devant être analysé. De cette façon, 
la seule information que nous devions fournir à 
partir du système d’exploitation était l’adresse de 
départ du programme BASIC; la fin du pro- 
gramme était repérée en recherchant le numéro 
de ligne le plus bas du programme utilitaire. 

L’utilitaire que nous créons est un programme 

de remplacement de variable. Ce programme est 
très pratique : si vous avez utilisé un nom de 
variable dans un programme et que vous décou- 
vrez que celui-ci est incorrect, vous imaginez aisé- 
ment le temps que ce type de programme pour- 
rait vous faire gagner. Il en va de même si vous 
avez écrit un programme susceptible d’être uti- 
lisé par d’autres personnes, dans lequel les noms 
de variables sont peu évocateurs. 
Dans cette partie, nous devons mettre le pro- 
gramme utilitaire dans une section séparée de 
mémoire, isolé du programme sur lequel il tra- 
vaille. Nous devons trouver une méthode diffé- 
rente pour déterminer la fin du programme 
BASIC et une façon d’accueillir deux programmes 
BASIC en même temps dans l’ordinateur. 

Les trois ordinateurs que nous examinons 
— le BBC Micro, le Commodore 64 et le Sinclair 
Spectrum — utilisent un jeu de pointeurs pour 
indiquer au système d’exploitation et à l’interpré- 
teur BASIC où trouver les programmes BASIC et 
les variables, etc. 

Sur le BBC Micro, il y a quatre pointeurs 
importants : PAGE et TOP, qui mémorisent les 
adresses de début et de fin du programme BASIC; 
LOMEM qui mémorise l’adresse de départ des 
variables BASIC; HIMEM, qui mémorise l’adresse 
finale de la zone BASIC. Ces quatre pointeurs 
sont stockés comme variables BASIC intégrées, et 
nous pouvons lire ou modifier leurs valeurs au 
moyen de simples instructions BASIC. Si nous 
avons un simple programme BASIC en mémoire 
et que nous désirons en ajouter un autre, nous 
donnons une valeur plus élevée à PAGE qu’à TOP 
— à l’aide de la commande OLD pour remettre à 
zéro TOP et LOMEM. Nous pouvons alors ajouter le 
nouveau programme sans modifier l’original. 
Nous passons d’un programme à l’autre en don- 
nant de nouvelles valeurs à PAGE et à HIMEM en uti- 
lisant la commande 0LD. 

Dès que le programme utilitaire fonctionne, les 
valeurs des pointeurs correspondent au pro- 
gramme utilitaire; pour permettre à celui-ci de 
trouver le début et la fin du programme à modli- 
fier, nous devons copier les valeurs initiales dans 


une zone de mémoire qui ne sera pas modifiée 
lorsque nous changerons les programmes. Il est 
aussi possible de trouver la fin d’un programme 
en utilisant un marqueur placé par l’interpréteur 
BASIC. Il s’agit simplement d’un octet contenant 
une valeur de 128 ou plus, suivant immédiate- 
ment le caractère retour de chariot placé à la fin 
de la dernière ligne du programme. Cet octet et 
le suivant seront interprétés comme les octets HI 
et LO du prochain numéro de ligne. Puisque 
l’octet HI de ce numéro est 128 ou plus, cela 
donne un numéro de ligne de 32768 (256 X 128) 
ou plus. Comme le numéro de ligne valide le plus 
élevé est 32767, nous pouvons être certains 
d’avoir trouvé le marqueur de fin de programme 
et non seulement un autre numéro de ligne. 

Le Commodore 64 utilise plusieurs pointeurs, 
stockés dans la mémoire de page zéro, pour indi- 
quer diverses parties de la zone de programme 
BASIC. TXTTAB, aux adresses 43 et 44, pointe le 
début du programme BASIC; VARTAB, ARYTAB, 
STREND, FRETOP et FRESPC, aux adresses 45 à 54, 
pointent diverses sections de la table de variables ; 
et MEMSIZ, aux adresses 55 et 56, pointe la fin de 
la zone BASIC. Il est possible de changer ces 
pointeurs afin de créer une zone distincte où exé- 
cuter un programme BASIC au moyen de la com- 
mande POKE. Cependant, il est préférable d’uti- 
liser un court programme en langage machine : 
puisqu'il est plus direct, il réduit les risques de 
blocage de l’ordinateur à la suite d’une erreur de 
frappe. 

Dans le Commodore 64, la fin d’un pro- 

gramme BASIC est indiquée par 2 octets renfer- 
mant des zéros placés immédiatement après 
l’octet zéro qui désigne la fin de la dernière ligne 
du programme. Pour trouver la fin d’un pro- 
gramme, il suffit d'examiner les chaînes de poin- 
teurs placées au début de chaque ligne jusqu’à 
la rencontre d’un pointeur zéro. 
La création de ce programme est plus compliquée 
sur le Spectrum. Au lieu d’une zone de mémoire 
distincte pour le programme BASIC, un seul bloc 
de mémoire continu se présente. Il contient non 
seulement le programme et les variables BASIC, 
mais aussi les zones d’espace de travail de 
mémoire utilisées par le système d’exploitation 
et par l’interpréteur BASIC. 

Avec cette disposition de mémoire, il est diffi- 
cile, sinon impossible, de placer deux program- 
mes BASIC dans la principale zone de travail; 
nous ferons donc une copie de notre programme 
au-dessus de RAMTOP et le modifierons à cet 
endroit. Mais nous devons également récupérer 
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le programme et le reloger dans la principale zone 
de programme après l’avoir modifié. Nous 
aurons besoin d’un programme en code machine 
pour le faire. 

Le manuel du Spectrum nous apporte beau- 
coup d’informations sur le mode de stockage 
d’un programme BASIC comme sur l’utilisation 
des diverses zones de mémoire. Cependant, en 
raison du grand nombre de sections différentes 
de la zone de travail, et de leur mode de déplace- 


Expérience avec basic 


Vous pouvez modifier le contenu d’un 
programme pendant l'exécution, mais vous 
devriez d’abord sauvegarder le programme, 
puisqu'il arrive fréquemment que cela bloque le 
système. Utilisez le programme Moniteur qui 
vous permet d'examiner et de modifier le 
contenu de la mémoire. Insérez quelques lignes 
REM supplémentaires au début du programme et 
essayez ces suggestions : 

- Trouvez le début de la zone de texte BASIC et 
inspectez le programme Moniteur en mémoire 
jusqu'à ce que vous puissiez identifier les lignes 
de programme. 

+ Changez les valeurs des octets placés après 
un REM élémentaire, puis quittez le programme et 
listez la ligne modifiée. 

- Essayez de mettre une valeur supérieure à 127 
dans une ligne REM; de nouveau quittez et listez. 
+ Modifiez d’une ligne les octets de numéro de 
ligne : les conséquences sont imprévisibles. 

e Vous pouvez modifier les octets de longueur de 
ligne — essayez de diminuer d’abord la longueur 
indiquée —, mais vous devez insérer un nouveau 


500 REM**EXEMPLE** 
Version du BBC 


Marqueur 
de début 
de ligne 


Numéro Jeton 


de ligne 


Longueur 
de ligne 


Version du Commodore 64 


ment, il est difficile d’écrire des programmes uti- 
litaires sans utiliser des sous-programmes en lan- 
gage machine logés en ROM. Si vous désirez 
écrire des utilitaires évolués sur le Spectrum, il 
existe d’excellents ouvrages où est expliqué com- 
ment fonctionnent toutes les routines en ROM. 
Deux des sous-programmes les plus importants 
logés en ROM destinés à être utilisés dans les pro- 
grammes utilitaires sont les routines qui ouvrent 
et sollicitent de l’espace dans la zone de travail. 


marqueur de fin de ligne à l’octet indiqué. 

+ Sur le Commodore 64, vous pouvez changer les 
octets d'adresse de chaîne : essayez de 
remplacer une adresse de chaîne d’une ligne par 
l'adresse de chaîne de la ligne suivante. 

+ Si vous vous sentez plus ambitieux, consultez 
votre manuel et explorez la zone de stockage 
des variables. Elle commence habituellement à 
l'endroit où se termine la zone de texte Basic. Il y 
a jusqu’à six types de variables, chacun ayant 
son propre format de stockage : les variables 
numériques, les tableaux numériques, les 
variables de nombres entiers, les tableaux de 
nombres entiers, les variables de chaînes, les 
tableaux de chaînes. Les formats de variables de 
chaînes et de nombres entiers sont les plus 
simples, les données de tableaux numériques 
sont les plus compliquées. 

+ Vous pouvez changer les valeurs élémentaires 
dans des lignes de programme, ce qui changera 
le mot de commande. Si vous faites cette 
intervention sur une ligne en cours d'exécution 
avec le programme Moniteur, vous introduirez un 
paradoxe potentiellement important dans 
l'interpréteur. 


Comment sont stockés les programmes basic 


La plupart des micros obéissent au même format de stockage dans 
la zone de programme BASIC. Chaque ligne de programme commence 
par les données de ligne : numéro de ligne BASIC dans 2 octets 

et une certaine information concernant la longueur de la ligne. Le 
texte du programme est stocké sans modification importante, bien 
que les mots clés BASIC soient remplacés par des numéros de code à 


1 octet nommés « jetons ». 


HI LO R 
13 lt 1241 17 |'& : E X E M L E 


Texte du programme 


0 | H | W IH IR ; 
18 8 244 Î à E X E M L E 


Numéro & 


de ligne 


Adresse 
de chaîne 


Version du Spectrum 


Texte du programme 


H [wI|uwIumlInR 
1 M | 1 0 £ * E X E M L E 13 


Numéro Jeton 


de ligne 


Longueur 
de ligne 


Texte du programme 


Dans ce format, 13 (code 
ASCII de [RETURN)) est un 
marqueur de début de ligne; 
il est plus commodément 


: [es à la fin d’une ligne. 


a longueur de ligne n’a que 
1 octet, ce qui limite 
les lignes de programme à 
255 caractères. L'espace 
apparaissant immédiatement 
après le numéro de ligne 
a été stocké. 


Les octets d'adresse de 
chaîne renferment l'adresse 
à 2 octets du premier octet 
de la prochaine ligne de 
programme. La zone de texte 
de programme BASIC 
commence à l'adresse 2049, 
et cette ligne a une longueur 
de 17 octets, l'adresse de 
départ de la ligne suivante 
est donc 2066. 


Pour le Spectrum, la longueur 
de ligne occupe 2 octets; une 
simple ligne de programme 
peut donc avoir une longueur 
de 65 535 caractères! La 
longueur de ligne est ici 13 
— les octets faisant partie 
de la ligne incluant l’octet de 
fin de ligne, mais n’incluant 
pas les octets de données 
de ligne. 


1185 


Les capacités de LOGO sur Atari sont particulièrement brillantes. 
Ses commandes définissent des figures, déterminent leur vitesse 
et permettent un grand choix de couleurs. 


LOGO sur Atari peut mettre en œuvre quatre 
figures graphiques (ou lutins) de 0 à 3, O étant 
la tortue par défaut. Le manuel Atari les appelle 
«tortues » plutôt que figures, et nous ferons de 
même. 

DIRE 1 fait de la tortue 1 la tortue courante. La 
tortue 1 obéira donc à toutes les commandes que 
vous passerez. Essayez par exemple : 


DIRE 1 
AV 40 
DR 90 
DIRE 2 
AR 40 
DR 9% 
DIRE 3 
DR 9 


Mais vous pouvez avoir plus d’une tortue cou- 
rante : 


DIRE [1 23] 
AV 50 


Les trois tortues désignées obéiront aux 
commandes. 

Les quatre tortues ont au départ la forme de 
la tortue 0 (jusqu’à ce qu’elles soient définies 
explicitement). 

EDFORME 1 fera éditer la forme 1 par l’éditeur. 
Les touches curseur vous permettront de vous 
déplacer librement sur l’écran. La barre d’espa- 
cement transformera un pavé graphique vide en 
pavé rempli d’une couleur, et un pavé plein en 
un pavé vide. La touche d’échappement <ESC> 
permet de définir une forme dessinée à l’écran. 
La commande ATTRIBUE 1 permet d’attribuer la 
forme 1 aux tortues 1, 2, 3 (les tortues courantes). 

DEMANDE permet d’effectuer une commande par 
une tortue sans changer la tortue courante : 


DEMANDE 1[AV 20] 


Seule la tortue 1 a bougé. Si vous tapez AV 2, 
h vous verrez que les trois tortues ont avancé, car 
» elles sont toujours numérotées 1, 2 et 3. 
Outre une direction et une position, les tortues 
peuvent recevoir une vitesse DONNEVITESSE 30 donne 
à la tortue courante la vitesse 30 selon sa direc- 


tion initiale. Les tortues garderont la même 
vitesse de déplacement jusqu’à ce que cette der- 
nière soit modifiée. Vous pouvez exécuter des 
procédures et créer des dessins, la vitesse ne 
change pas. Pour arrêter les tortues, donnez-leur 
une vitesse 0. Le fait de passer dans le mode édi- 
teur les arrêtera également, puisque l’éditeur, uti- 
lisant la même zone mémoire, détruit l’affichage 
graphique. 

Atari autorise cent vingt-huit nuances. Vous 
pouvez choisir la couleur du fond, celle du crayon 
et celle de la tortue. Par exemple, DONNECOULEUR- 
FOND 92 donnera au fond la couleur verte. DONNE- 
COULEURCRAYON 0 3 donnera la couleur orange au 
crayon. 23 est le code pour la couleur orange, et 
0est le code pour le numéro du crayon. Avec le 
LOGO d’Atari, il est possible d’utiliser trois 
crayons, mais nous n’utiliserons ici que le crayon 
0 (le crayon par défaut). Ici, DONNECOULEUR 7 don- 
nera la couleur blanche à la tortue courante. 

L'aspect le plus original de LOGO sur Atari est 
l’utilisation des « DÉMONS ». LOGO peut détec- 
ter jusqu’à vingt et un types de collisions et autres 
situations. Essayez par exemple ceci : 


COLLISION 
DIRE 0 
POSEPLUME 
AV 50 
LÈVEPLUME 
DR 9 

AV 100 

DR 90 

AV 20 

DR 90 


Mettez alors en place un démon LORSQUE par la 
commande suivante : 


LORSQUE O[AR 50] 


Rien ne se passe dans l’immédiat, mais le démon 
0 est dans l’ordinateur, montant la garde contre 
la situation 0. Faites maintenant DONNEVITESSE 30. 
La tortue se dirige vers la ligne-situation, mais 
au moment de l’atteindre, le démon LORSQUE est 
mis en branle, et la tortue est rejetée en arrière. 
Elle reprend sa marche à la vitesse 30, mais est 
rejetée à nouveau à l’approche de la ligne. 


Ce démon LORSQUE reste en activité jusqu’à ce 
que vous le supprimiez par LORSQUEO[]. Taper COL- 
LISION supprimera tous les démons. Mais un mes- 
sage d’erreur ou l’utilisation de l’éditeur les sup- 
primera aussi bien. 

Comme il est fastidieux d’avoir à se rappeler 
tous les codes de collisions, deux primitives vous 
y aideront : AU.DELÀ <numéro de la tortue> <numéro du crayon> 
vous communiquera le numéro de la collision 
entre la tortue et une ligne tracée par le crayon. 
TOUCHE <numéro de la tortue 1> <numéro de la tortue > donne le 
numéro du démon chargé de la collision entre ces 
tortues. 


Mettre la tortue en cage 


Voici une procédure pour mettre en cage une tor- 
tue. Chaque fois qu’elle heurte les parois (LORS- 
QUE AU.DELÀ 0 0), un démon appelle la procédure 
TOURNE. Cela fait revenir la tortue en arrière de 
10 unités, après quoi elle effectue un tournant au 
hasard (AUHASARD, avec un numéro, N, produit 
un nombre aléatoire compris entre O0 et N-1 
inclus). 


POUR PIÈGE. 
TRACE PIÈGE 
RETOUR 
LORSQUE AU.DELÀ 0 0 [TOURNE] 
DONNEVITESSE 50 
FIN 


POUR TRACE PIÈGE 
COLLISION 
LÉVEPLUME 
POSITIONNE [--50 50] 
POSEPLUME 
CARRÉ 
LÉVEPLUME 

FIN 


POUR CARRÉ 
RÉPÈTE 4 [AV 100 DR 90] 
FIN 


POUR TOURNE 

AR 10 

DR AU.HASARD 45 
FIN 


Les démons peuvent également être affectés à la 
manette de jeu. Parmi les vingt et une situations 
que nous avons citées, la situation 3 se produit 
lorsque l’on appuie sur la manette, et la situa- 
tion 15 lorsque sa position est modifiée. La com- 
mande MAN 1 produit un nombre compris entre 
—l:et 7, correspondant à la position de la 
manette (relié par le port 2). Définissez DIRECTION- 
MANETTE de la manière suivante : 
POUR DIRECTIONMANETTE 
SI (MAN 1} « 0 [STOP] 
DEMANDE 0 [DONNEDIRECTION 45 * 


MAN 1] 

FIN 
Mettez ensuite la tortue en marche par DONNEV/- 
TESSE 50, et, en dernier lieu, placez un démon 
LORSQUE : 

LORSQUE 15 [DIRECTIONMANETTE] 

La manette peut alors être utilisée pour diriger 
la tortue O. 

Vous pouvez donner plus d’une commande 
LORSQUE à la fois, mais elles ne seront pas actives 
simultanément. Lorsqu’un démon est « occupé » 
(c’est-à-dire lorsque se réalise une situation), les 
autres sont inactifs. Ce qui signifie que certaines 
collisions peuvent ne pas être détectées. 

La solution est de faire mettre les vitesses à zéro 
par les démons, et de faire s’exécuter une procé- 
dure continue qui traite des vitesses. Voici com- 
ment adapter votre programme précédent à cette 
technique : 

POUR PIÈGE 

TRACE.PIÈGE 
RETOUR | 
LORSQUE AU.DELA 0 0 [DONNEVITESSE 0] 
SURVEILLANCE 
FIN 


POUR SURVEILLANCE 
SI VITESSE = 0 [DÉTECTION] 
SURVEILLANCE 
FIN 
Dans cette procédure, VITESSE donne la vitesse de 
la tortue courante. La procédure DÉTECTION doit 
déterminer la situation qui vient de se produire, 
prendre les mesures nécessaires et restaurer les 
vitesses appropriées. Dans le cas présent, il n’y 
a qu’une situation qui nous préoccupe, mais le 
principe vaut pour la méthode de pro- 
grammation. 
POUR DÉTECTION 
SI CONDITION AU.DELÀ 0 
0 ALORS [TOURNE] 
DONNEVITESSE 50 
FIN 
La commande CONDITION suivie d’un nombre 
donne un résultat VRAI si la situation correspond 
au nombre indiqué. CONDITION ne peut détecter 
une situation que lorsque L0G0 exécute la ligne 
où cette dernière se trouve. 


Encercler les moutons 


Voici un jeu qui met en œuvre beaucoup des 
caractéristiques que nous avons décrites. Le 
joueur utilise la manette de jeu pour contrôler 
le déplacement d’un chien qui court après deux 
moutons dans un champ. Lorsque les moutons 
se heurtent au grillage, ils reviennent en arrière 
et changent de direction. Lorsque les moutons se 
heurtent entre eux, ils tournent dans une direc- 
tion prise au hasard. Lorsque le chien attrape un 
mouton, ce dernier tourne de 90° à droite. En 


Kevin Jones 


Liz Dixon 


lan McKinnel 


Canis familiaris — le chien 


Ovis aries — le mouton 


Début du jeu 


Le jeu en pleine action 


Retour au bercail 


1188 


appuyant sur le bouton de la manette de jeu, on 
dessine une petite cage dans le coin inférieur gau- 
che du champ. En appuyant à nouveau sur ce 
bouton, on efface la cage. Le travail du chien 
consiste à traquer les moutons dans la cage. 


POUR CHASSE 
DONNE. VAR 
DEMANDE :TORTUE [INIT.ÉCRAN] 
DONNE.DÉMONS 

DÉBUT 
SURVEILLANCE 

FIN 

POUR DONNE.VAR 
FAIRE « GRILLAGE 0 
FAIRE « MOUTON 0 
FAIRE « MOUTONI 3 
FAIRE « MOUTON? 2 
FAIRE « CHIEN 1 
FAIRE « VERT 92 
FAIRE « ORANGE 23 
FAIRE « NOIR 0 
FAIRE « BLANC 7 

FIN 

POUR INIT.ÉCRAN 
COLLISION 
FORMEGRILLAGE 
DONNECOULEURFOND :VERT 
CACHETORTUE 
LÈVEPLUME 
POSITIONNE [- 150 —80] 
POSEPLUME 
DONNECOULEURCRAYON 0/:MARRON 
RECTANGLE 160 300 
LÉVEPLUME 

FIN 


POUR RECTANGLE :CÔTÉI :CÔTÉ? 
RÉPÊTE 2 [AV :CÔTÉT DR 90 AV :CÔTÉ2 
DR %) 

FIN 


POUR DONNE.DÉMONS 
LORSQUE AU.DELA :MOUTONT :GRILLAGE 
[DONNEVITESSE 0 
LORSQUE AU.DELÀ :MOUTON2 :GRILLAGE 
[DONNEVITESSE 0 
LORSQUE TOUCHER :MOUTON1 :MOUTON2 
[DONNEVITESSE 0 
LORSQUE TOUCHER :CHIEN :MOUTON1] 
[DONNEVITESSE 0 
LORSQUE TOUCHER :CHIEN :MOUTON2 
[DONNEVITESSE 0 
LORSQUE 3 [DONNEVITESSE 0] 
LORSQUE 15 [DIRECTIONMANETTE] 

FIN 


POUR DIRECTIONMANETTE 

SI (MAN 1} < O[STOP] 

DEMANDE :CHIEN [DONNEDIRECTION 45 * MAN 1] 
FIN 


POUR DÉBUT 
DONNE :MOUTONI [- 150 20] 45 :BLANC 
DONNE :MOUTON? 1 [150 20] 315: 
BLANC 
DONNE CHIEN 2 [0 0] 0 :NOIR 
DONNE.VITESSES 


FIN 


POUR DONNE :NO :FORME :POS :DIR: 

COULEUR 

DIRE :NO 

LÉVEPLUME 

DONNEFORME :FORME 

DONNECOULEUR :COULEUR 

DONNETORTUE 

DONNEPOS :POS 

DONNEDIR :DIR 
FIN 
POUR DONNE.VITESSES 

DEMANDE :MOUTON1 [DONNEVITESSE 10] 

DEMANDE ‘MOUTON? [DONNEVITESSE 10] 

DEMANDE :CHIEN [DONNEVITESSE 60] 
FIN 
POUR SURVEILLANCE 
SI VITESSE = 0 [DÉTECTION] 
SURVEILLANCE 
FIN 
POUR DÉTECTION 
SI CONDITION AU.DELÀ :MOUTONI: 
GRILLAGE [DEMANDE :MOUTONI 
AR 20 DR %]] 
SI CONDITION AU.DELÀ :MOUTONZ: 
GRILLAGE [DEMANDE :MOUTON2 
AR 20 DR 90]] 
SI CONDITION TOUCHE ‘MOUTON: 
MOUTON? [HEURT 
SI CONDITION TOUCHE :CHIEN: 
MOUTON1 [DEMANDE :MOUTONI 
DR %]] 
SI CONDITION TOUCHE :CHIEN: 
MOUTON? [DEMANDE :MOUTON2 
DR %]] 
SI CONDITION3 [DEMANDE :TORTUE 
TRACE. CAGE] 
DONNE. VITESSES 


FIN 
POUR HEURT 
DEMANDE :MOUTON1 [DONNEDIRECTION AU.HASARD 360] 


FIN 
POUR DESSINE.CAGE 
LÉVEPLUME 
POSITIONNE [150 —30] 
POSEPLUME 
DONNEDIR 90 
RÉPÈTE 2 [AV 50 DR %] 
LÉVEPLUME 


hd 
Quatre à quatre 


Après l’énorme succès du 64, le Plus/4 de Commodore représente un 
grand pas en avant : un BASIC bien supérieur, quatre logiciels 
intégrés, et 64 K de RAM directement accessibles par l’utilisateur. 


Commodore prend bien soin de préciser que 
le Plus/4 n’a pas pour but de remplacer le 64; 
mais il a tant de possibilités supplémentaires 
qu’il pourrait bien éclipser complètement son 
prédécesseur. 

Le Plus/4 est construit autour du micropro- 
cesseur 7501, qui dérive du 6502. Cette puce est 
conçue de façon à pouvoir manipuler plus de 
64 K d’espace mémoire. L’usager aura donc toute 
la RAM à sa disposition et bénéficiera en même 
temps d’un BASIC décent. De fait, un programme 
BASIC peut atteindre jusqu’à 64 K (50 seulement 
s’il est fait usage de graphismes). 

Le Plus/4 est de surcroît doté d’une excellente 
version du BASIC Microsoft, en particulier au 
niveau des commandes graphiques et sonores. 
DRAW trace des points et des lignes; PAINT remplit 
de couleurs des formes; BOX crée des carrés et 
des rectangles, que ce soient des blocs de couleur 
ou de simples contours; CIRCLE est d’un usage 
extrêmement souple. On peut tracer des cercles, 
mais aussi des ovales (en spécifiant la hauteur et 
la largeur), et même des arcs, en précisant sim- 
plement le point de départ et le point d’arrivée. 

Toutes ces commandes fonctionnent en mode 
graphique, avec une résolution de 320 x 200 
pixels. C’est la même que celle du 64, mais le 
Plus/4 a un nombre de couleurs infiniment plus 
élevé : 120 (plus le noir) d’entre elles peuvent 
être affichées simultanément. Il s’agit en fait 
de 15 teintes de base, dont chacune possède 
8 niveaux de luminosité. Un gros regret toute- 
fois : le Plus/4 n’a pas de lutins ce qui ne man- 
que pas d’étonner pour une mächine aussi 
récente. 


Un basic enrichi 


Le contrôle du son est assuré par le biais de 
commandes tout à fait familières. SOUND joue 
une note dont il faut spécifier la hauteur et la 
durée. VOL attribue au volume l’une des huit 
valeurs possibles sur un des deux canaux existant 
sur l’appareil, bien que le BASIC permette d’en 
manipuler trois : le « troisième » est en fait un 
générateur de bruit blanc, ce qui est très utile dans 
les jeux. Les sons produits sont émis à travers le 
haut-parleur du téléviseur ou du moniteur. 

Le BASIC proprement dit a été enrichi de nom- 
breuses fonctions très utiles. AUTO crée automa- 
tiquement de nouveaux numéros de ligne 
lorsqu’on tape un programme; RENUMBER leur 
donne ensuite des valeurs nouvelles et VERIFY per- 
met de s’assurer que la sauvegarde (sur cassette 


ou sur disquette) s’est opérée correctement. De 
nombreuses commandes contrôlent le lecteur de 
disquettes. Le Plus/4 affiche 25 lignes de 
40 caractères. Il est possible de choisir deux points 
sur l’écran et d’en faire les coins d’une « fenêtre ». 
Tout ce qui est texte (listages, commandes) 
n'apparaîtra qu’à l’intérieur de cette fenêtre, sans 
que le reste de l’affichage ne soit modifié. 

Les touches du Plus/4 sont très sensibles, et 
une légère pression suffit. Certains caractères 
(@ , =, + ou —) se sont vu attribuer une tou- 
che séparée, et on peut également accéder aux 
caractères graphiques de façon directe. Quatre 
touches de fonction sont installées en haut du cla- 
vier; une fois l’ordinateur placé sous tension, 
elles sont automatiquement activées, de façon à 
produire les commandes les plus usitées. Il est par 
exemple tout à fait envisageable de créer une nou- 
velle commande comportant jusqu’à 128 carac- 
tères, et ce pour une seule touche. Grâce à 
l'emploi de la touche SHIFT, les touches de fonc- 
tion peuvent donc assurer jusqu’à huit rôles 
différents. 

Le vaste espace mémoire du Plus/4 permet 
d’accueillir quatre logiciels intégrés : un traite- 
ment de texte, un tableur, une base de données, 


rar 


L'U1S | 


# 
# 
po) 
- 
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Ÿ 
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KL 
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ls . 
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L'avenir ? 

S'il s'est fait longtemps 
attendre, le successeur 
du Commodore 64 a de 
nombreuses 
caractéristiques propres 
aux micro-ordinateurs les 
plus récents : conception 
de type MSX, pavé 
curseur, vaste mémoire 
et logiciels intégrés. Mais 
la concurrence est 
extrêmement forte, 

et l'acheteur potentiel 
mieux informé que 
jamais. 

(CI. Chris Stevens.) 
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Le QL face au Plus/4 

Objectivement, la comparaison semble sans objet : le 
QL dispose de Microdrives, de bons logiciels intégrés, 
d'une mémoire plus vaste et du superBasic, le tout 
pour 6 000 F environ; pour un prix à peine inférieur 
(lecteur de cassettes compris), le Plus/4 ne peut guère 
faire valoir que son clavier. Mais l'achat d’un appareil 
se fait rarement sur des critères aussi techniques, 

et le consommateur choisit souvent au sentiment. 

(CI. lan McKinnell.) 


un programme graphique. Tous ces logiciels sont 
censés pouvoir travailler ensemble. 

Malheureusement, le traitement de texte n’est 
pas d’un emploi très facile. Le Plus/4 ne peut 
afficher simultanément que 40 caractères, alors 
que la plupart des imprimantes ont une capacité 
double. L’écran se déplace donc dès que l’on a 
atteint la trente-septième lettre, et ce jusqu’à la 
soixante-dix-septième ; il revient alors à son point 
de départ. Certaines commandes de mise en 
forme permettent de fixer les marges et de justi- 
fier le texte, mais leur effet n’est visible qu’à 
l'impression. SEARCH et REPLACE retrouvent certains 
mots ou certaines phrases dans le corps du docu- 
ment et les remplacent au besoin par quelque 
chose d’autre. Malheureusement, il n’est pas pos- 
sible d’entrer plus de 99 lignes de texte. 

Si le tableur est de maniement plus aisé, il souf- 
fre lui aussi d’un affichage limité à 40 colonnes. 
En effet, il ne peut présenter à la fois que trois 
cases en largeur et douze en profondeur, bien 
qu’il puisse gérer des modèles de 17 cases sur 50. 


Des surprises 


Le logiciel graphique est très décevant. Il se 
borne, à partir des données fournies par le 
tableur, à créer des graphiques assez sommaires 
réalisés avec de simples blocs, et à les transmet- 
tre au programme de traitement de texte. Ils peu- 
vent être imprimés ou simplement affichés. Un 
résultat encore surprenant et bien décevant. 
Bien que le traitement de texte et le tableur 
puissent être mis en œuvre directement, on ne 
peut sauvegarder les résultats obtenus que sur dis- 
quette. Cela signifie qu’il y a peu de possibilités 
pour les utilisateurs de mémoires à cassette. 
Le dernier programme, la base de données, ne 
peut fonctionner sans ce périphérique. Un for- 
mat standard est défini, puis stocké sur disquette, 
sous forme de fichier « vide », au sein duquel on 
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Bus série 

Des périphériques 
Commodore (lecteur de 
disquettes, imprimante) 
viennent s'y enficher. 


Prise cassette 

C'est là que s'adapte 
le lecteur de cassettes 
(propre à l'appareil). 


Port 
utilisateur 


Prises manches à balai 
Elles accueillent les deux 
manches à balai, eux 
aussi spécifiques; on ne 
peut en utiliser d’autres. 


Prise de sortie vidéo et son 


Modulateur TV 

Il transmet un signal à un 
récepteur de télévision 
ordinaire. 


Boîtier UAL 

Une grande UAL (unité 
arithmétique et logique) 
est placée à l’intérieur de 
ce boîtier métallique, qui 
la protège des 
interférences radio. 


ROM 

Les ROM contiennent le 
8asic et les logiciels 
intégrés. 


entre ensuite les données nécessaires. Cela veut 
dire qu’une disquette ne peut servir que pour une 
seule base de données, et surtout qu’il n’est pas 
possible de modifier le format général une fois 
les informations stockées. Chaque fichier peut 
contenir jusqu’à 999 fiches, dont chacune ren- 
ferme un maximum de 17 rubriques de 38 carac- 
tères. 

Dans l’ensemble, il faut bien dire que le logi- 
ciel n’est pas à la hauteur de ce que l’on pouvait 
espérer pour une telle machine. Ils sont trop pri- 
maires pour être utilisés en gestion, et il est indis- 
pensable, pour en faire usage, d’acquérir un lec- 
teur de disquettes, d’où des frais supplémentaires. 

L'utilisateur, en revanche, appréciera sans 
doute vivement Tedmon, le moniteur langage 
machine, qui peut être mis en route par la com- 
mande MONITOR. 

Commodore a aussi prévu de nombreux péri- 
phériques pour le Plus/4. Le plus important est 
sans doute le lecteur de cassettes, qui, dans la 
bonne tradition de la firme, est spécifique à 
l’appareil ! En outre, il est impossible d’employer 
les lecteurs du Vic-20 ou du 64, la prise n’étant 


qableur 


Touches 

de fonction 
Chacune peut être 
programmée de 
façon à produire 
deux commandes. 


Pavé curseur 


Prise d'alimentation 


Commutateur on/off 


Bouton 
de remise à zéro 


UC 7501 


RAM de 64 K 


Port d'extension 
Utilisé par les 
logiciels sur 
cartouche et par un 
lecteur de disquettes 
« rapide » 


Touches de fonction 


= commodore (LULU 


Touche curseur 


Bouton de remise à zéro 


Type machine à écrire, 
67 touches dont 4 touches 


Port d'extension et utilisateur 


Du nouveau: 


Les vieux amateurs de Commodore apprendront avec 
intérêt que le Plus/4 est doté de touches ESCAPE et RESET, 
d’un pavé curseur, de touches de fonction 
programmables à partir du sasic et d’une touche HELP. 
Toutefois, la prise d'alimentation, les prises cassettes 
et manches à balai, les ports d'extensions 

et utilisateurs sont tous incompatibles avec ceux 

du Vic-20 et du Commodore 64. (CI. Chris Stevens.) 


Nécessité d'un lecteur de 
cassette spécifique, manches 
à balai non standards. 


Des frais a 


supplémentaires 


Le Plus/4 comporte 
quatre logiciels intégrés : 
un traitement de texte, 
un tableur, une base de 
données et un utilitaire 
graphique; mais ils ne 
fonctionnent réellement 
qu'avec un lecteur de 
disquettes, ce qui accroît 
de façon importante le 
prix réel de l'appareil. 
(CI. lan McKinnell.) 


pas la même! Et c’est aussi le cas pour les 
manches à balai. 

Le Plus/4 peut fonctionner avec une variante, 
légèrement modifiée, du lecteur de disquettes 
1541, bien connu pour sa lenteur. Commodore 
a promis une nouvelle version, plus rapide, qui 
s’enficherait dans le port cartouche. Par ailleurs 
la firme propose cinq imprimantes différentes : 
une à marguerite, trois matricielles (dont une en 
couleur) et une imprimante-table traçante à qua- 
tre stylos à bille de couleur. Mais ce n’est encore 
qu’une proposition pour l'avenir. proche 
toutefois. 

Si le Plus/4 est vendu à un prix un peu plus 
élevé que le 64, un BASIC bien supérieur et un 
espace mémoire plus vaste en font toutefois un 
achat très intéressant. Nous consacrerons ulté- 
rieurement un article au fonctionnement du son 
BASIC. Bien entendu, il lui faudra se tailler une 
place sur le marché avant qu’apparaissent des 
programmes qui lui seront consacrés ; mais vu la 
place prépondérante de Commodore dans le 
domaine de la micro-informatique individuelle, 
cela ne devrait pas être difficile. 
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ET 
Envoyez les clones 


Nous allons étudier les caractéristiques de Vu-Calc, un progiciel 
tableur et générateur de modèles financiers, de remboursement 
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d'emprunts et de prêts bancaires. 


Le point fort des programmes tableurs, même 
avec un simple progiciel comme Vu-Calc de 
Psion, est de pouvoir appliquer des formules 
mathématiques complexes aux données. Comme 
nous allons le voir, il est possible d’établir des 
modèles de calcul intéressants et très utiles avec 
Vu-Calc, bien que ce programme ne prévoie pra- 
tiquement rien comme formules mathématiques 
intégrées, à l’exception de la somme d’ensembles 
de positions (que l’on indique en préfixant 
l’adresse de la case, du signe © ou @). 

Les tableurs plus sophistiqués comportent des 
formules mathématiques poussées que l’utilisa- 
teur peut appeler en utilisant leur nom. L’avan- 
tage d’un tel système est que vous n’avez pas à 
vous préoccuper de la manière dont les calculs 
sont effectués. Si vous voulez utiliser une formule 
mathématique de calcul des mensualités de rem- 
boursement d’un emprunt immobilier avec Mul- 
tiplan par exemple, sur plusieurs périodes de 
temps, disons quinze, vingt et vingt-cinq ans, 
vous devez seulement appeler la formule et sai- 
sir les données appropriées. Multiplan se charge 
de trouver les réponses. 

Avec Vu-Calc, les mêmes calculs prendront 
beaucoup plus de temps et d’efforts. Vous devrez 
établir vous-même les formules voulues et les 
entrer dans la machine. Vu-Calc impose à l’uti- 
lisateur un certain nombre de contraintes. Il com- 
porte un maximum de vingt-huit colonnes, ce qui 
signifie que le plus grand modèle que vous pou- 
vez faire, avec une colonne par mois, portera seu- 
lement sur une période de deux ans. Un problème 
de précision des calculs se posera également : Vu- 
Calc, ne travaillant qu’avec des nombres entiers, 
ignore les chiffres après la virgule. Pour lui, 99,5 
est égal à 99! Il autorise la saisie de valeurs et 
d’opérations arithmétiques en tous points du 
modèle. Par exemple, lorsque le curseur est situé 
sur une case vide (prenons H5), vous pouvez 
taper 50°? sur la ligne de commande. La touche 
d’exécution affiche le résultat, 1000, à la case H5. 

Une autre tracasserie, propre à Vu-Calc, 
concerne l’édition des formules. Un bon progi- 
ciel comme Lotus 1-2-3 utilise une touche de 
fonction pour l’édition. Sa frappe positionne 
automatiquement le contenu de la case du 
curseur sur la ligne de commande. Vu-Calc 
comporte une commande ÉDIT (+) à utiliser 
lorsqu’une formule doit être modifiée, mais la 
formule doit être retapée à chaque nouvel usage 
de la commande d’édition. Si vous travaillez sur 
une formule assez longue et que vous apercevez 
une parenthèse oubliée, il ne vous sera pas pos- 


sible de l’insérer. Toute la ligne devra être reta- 
pée. L’action de EDIT se limite à effacer 
l’ancienne formule et à la remplacer par la 
nouvelle. 

La commande REPLICATE (#R) associée à une for- 
mule permet de créer des modèles assez com- 
plexes. Supposons que vous vouliez approfondir 
l’application « budget familial », pour évaluer 
à l’avance l’effet de l’inflation sur le poste 
« nourriture », en vous basant sur un taux 
d'inflation de 0,5 % par mois. Le calcul à la main 
prendrait manifestement beaucoup de temps. 
Avec Vu-Calc, cela se fait très rapidement par 
l’intermédiaire de la commande REPLICATE. 

Pour mener à bien l’opération, vous deman- 
dez à Vu-Calc d’augmenter votre budget initial 
mensuel (par exemple de 2 000 F), de 0,5 %. Vu- 
Calc suppose que l’on saisisse les opérations 
arithmétiques à effectuer (on utilise la commande 
GROWBY avec des tableurs plus élaborés). Afin 
qu’il soit à même de reconnaître une formule 
comportant des adresses de positions, la formule 
doit être précédée soit de « $ », soit de « % ». Il 
s’agit de deux signes arbitraires qui n’ont rien à 
voir avec les dollars ni avec les pourcentages, 
mais qui indiquent que les adresses de la formule 
doivent être prises en considération et qu’elles 
sont soit relatives (%), soit absolues ($). Une 
référence absolue à une position ordonne au pro- 
gramme d’intervenir sur une valeur d’une case 
spécifique, sans tenir compte de sa position. 

Revenons à notre exemple, pour voir à quoi 
correspond une position relative. La formule, 
pour accroître le budget de 0,5 %, est 
%B3*100.5/10, avec % pour indiquer l’adresse rela- 
tive de la position, et B3 pour l’adresse de la 
valeur du poste mensuel « nourriture ». Ayant 
mis cette formule dans la case B4, nous devons 
encore la reproduire sur l’ensemble du tableau 
pour toute l’année. B4 affiche le résultat numé- 
rique de la formule, celle-ci apparaissant en bas 
du document lorsque le curseur est en B4. La 
commande REPLICATE :#R,84,B5:B14 donne le résultat 
voulu (84 contient la formule, B5:B14 définit 
l’ensemble des cellules concernées). Les résultats 
sont affichés presque instantanément, notre 
modèle de tableau électronique ayant alors 
l’aspect suivant : 


L'affichage montre pourquoi B3 est utilisé 
comme valeur mensuelle initiale du budget; 
l’appellation porte sur les colonnes Î et 2, et 
nous commençons en colonne 3 pour une meil- 
leure lisibilité du tableau. Vous remarquez que 
toutes les valeurs sont des nombres entiers — la 
colonne MARS devrait contenir la valeur 2020,50, 
mais le tableur arrondit à la décimale inférieure, 
ce qui affiche 202 tout rond. Le chiffre pour 
AVRIL est en réalité de 20%0,1502, Vu-Calc le résultat 
à 203. Comme l’accroissement dû à l’inflation 
est davantage prononcé d’un mois sur l’autre, 
l’écart entre la valeur réelle et la valeur affichée 
augmente de plus en plus. 

Ce simple exemple montre l’effet de la com- 
mande REPLICATE lorsqu'elle est utilisée sur des 
adresses relatives. Chaque fois que le programme 
réécrit la formule une position plus à droite, la 
formule est modifiée en conséquence. Notre for- 
mule originelle en B4 était %B3*100.5/100. La for- 
mule est recopiée en B5 comme %B4*100.5/100; en B6 
comme %B5°100.5/10, etc. Chaque fois, le numéro 
de colonne de l’adresse est augmenté d’une 
valeur. La recopie d’une formule en descendant 
une colonne a le même effet sur les adresses (Ei 
devient F1, etc.). Si nous avions utilisé des adres- 
ses absolues au lieu d’adresses relatives, ce déca- 
lage ne se serait pas présenté. La même formule 
aurait été recopiée à toutes les positions, et la 
valeur de chacune identique à celle de B4. 
Essayons d’appliquer maintenant le même 
modèle à l’estimation du coût mensuel d’ap- 
provisionnement en matières premières d’une 
société. La valeur d’origine est de 100 000 F 
par mois, et l’accroissement est de 0,5 % par 
mois sur deux ans. Quel coût supplémentaire 
représenterait l’achat des produits en milieu de 
deuxième année? Le modèle nous permet d’effec- 
tuer ce calcul très rapidement. 


Transformez en 100 000 la valeur en B3, en 
déplaçant le curseur en B3 et en entrant le nou- 
veau chiffre. Utilisez maintenant la commande 
REPLICATE pour étendre la formule aux positions 
B14 à B26, sur toute l’année. Avec Vu-Calc, vous 
devez recalculer les résultats (qui sont alors tou- 
jours fondés sur l’ancienne formule), en utilisant 
la commande CALCULATE, #C. Vu-Calc calcule alors 
les nouvelles valeurs et affiche le résultat voulu 
en B2. Si vous appliquez cet exemple, vous 
obtiendrez 109 931 F, soit une augmentation de 
pratiquement 10 000 F. Il ne s’agit pas d’une 
valeur précise, puisque tous les chiffres sont 
arrondis, mais elle est assez représentative pour 
donner une idée de l’effet de l’inflation sur cette 
période. 

Comme dernier exemple d’un problème por- 
tant sur une seule ligne de tableau, envisageons 
une formule de modèle financier plus complexe. 
Il s’agit de calculer le solde en voie de diminu- 
tion d’une dette de 1 000 F sur une carte de cré- 
dit ou sur un emprunt bancaire, avec des inté- 
rêts de 27 % par annuité. En supposant que 80 F 
soient remboursés chaque mois, au bout de com- 
bien de temps la dette sera-t-elle apurée? Les 
informations nécessaires pour ce calcul sont le 
montant principal de l’emprunt, le taux d’inté- 
rêt pour un mois et le remboursement mensuel. 
Si nous entrons la valeur 1000 en Bi, la formule 
sera %B1+9%B1*.27/12-80. 

Recopiez la formule sur les 28 colonnes du 
modèle, passez en revue la rangée pour voir à quel 
moment la valeur devient positive, et vous sau- 
rez à partir de quand la dette sera remboursée et 
quand vous deviendrez créditeur si les versements 
continuaient. 

Selon notre modèle, il faudrait seize mois. Le 
tableau permet également de voir la balance men- 
suelle selon le même remboursement. 


DÉPENSES DU MÉNAGE 


BALANCE MENSUELLE 


Obtenir des nombres 

Ce convertisseur 
numérique/analogique 
montre un potentiomètre 
beaucoup trop important. 
Ce n'est pas nécessaire. | 
faut savoir, avant d'acheter 
des composants 
électroniques, ce à quoi ils 
vont servir. 

(CI. lan McKinnell.) 
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# e 
Contrôler la puissance 


La construction d’un convertisseur numérique/analogique va nous 
permettre de commander des dispositifs analogiques à partir du port 
utilisateur et de produire un son synthétisé numériquement. 


Pour ce projet, nous avons choisi d’utiliser une 
puce convertisseur numérique/analogique (N/A) 
prête à l’emploi, bien qu’il soit possible de cons- 
truire un circuit avec des composants discrets. 

La sortie analogique provenant de cette puce 
est shuntée par un amplificateur placé sur une 
seconde puce. La sortie qui en résulte est reliée 
directement à l’une des sorties, et par un conden- 
sateur et un compteur à l’autre. 

Étape 1. Coupez le boîtier pour placer les deux 
connexions du bus du système. Une prise peut 
aussi être coupée pour des projets futurs. 
Étape 2. Coupez la carte de montage de manière 
à avoir 16 bandes de 30 trous. Faites les rup- 
tures de pistes comme sur le diagramme. Soudez 
d’abord les prises de la puce, puis les liaisons des 
fils. Les deux condensateurs doivent ensuite être 
installés. Le sens n’a pas d’importance. Si vous 
désirez installer la prise d’extension de bus, 
soudez-la d’abord, et installez le câble-ruban. 
Étape 3. Placez les quatre prises dans le boîtier, 
avec le potentiomètre. Établissez les connexions 
entre celles-ci et le fil d’étain. Enfin, posez les 
trois conducteurs sur la carte. 

Étape 4. Enfichez les deux puces, et le conver- 
tisseur est complet. Notez que les deux puces ne 
s’enfichent pas dans le même sens : le convertis- 
seur N/A doit être positionné de telle sorte que 
l’encoche se trouve à gauche, vue du haut, le 
connecteur de bus mâles étant vu vers le haut, 
l’encoche de la puce amplifiant doit être à droite. 

Après avoir construit le convertisseur N/A et 
avoir soigneusement vérifié toutes les connexions, 
vous pouvez tester l’unité. Ce convertisseur trans- 
formera toute valeur binaire à 8 bits placée dans 
le registre de données du port utilisateur en une 
tension. Cette tension sort de l’unité de deux 
manières. 

Au niveau de la paire de prises de sortie CC 
(courant continu), une tension CC de 0 à 2,5 V 
est disponible, correspondant aux valeurs numé- 
riques du port utilisateur de 0 à 255. L'autre paire 
de sorties nous permet de simuler une sortie CA 
(courant alternatif). 

Le niveau de tension est commandé par un 
potentiomètre et peut être ajusté pour correspon- 
dre à l’entrée requise par un autre équipement. 

Pour tester l’unité, nous pouvons concevoir 
une expérience simple, qui modifie l’intensité 
d’une DEL (diode électroluminescente). Pour 
cela, suivez ces directives : 

Étape 1. Une DEL, du type utilisé dans le bof- 
tier tampon initial, doit être connectée en série 
à une résistance de 50 Q . 


Étape 2. Le convertisseur N/A doit être connecté 
directement au boîtier tampon, lui-même 
connecté au port utilisateur et alimenté de la 
manière habituelle. 

Étape 3. La DEL et la résistance doivent être 
connectées aux prises de sortie CC sur le conver- 
tisseur; et ce programme doit être exécuté : 


Potentiomètre 


10 REM ##kk PROGRAMME TEST CEM 64 N. A 4x 
20 DDR=56579:DATREG=56577 

30 VL=127 

40 POKE DDR; 255:REM TOUTES SORTIES 

Sa POKE DATREG, VL 

60 PRINT VL 

70 GET A$ 

80 IFA$<)"Z" AND A$<C»"X" 
90 IF A$="X" THEN DV=1 
100 1F A$="Z" THEN DV=-1 
118 VL=VL+DV 

120 IF VL<256 AND VL»=@ THEN 58 


THEN 78 


19 REM wkkk PROGRAMME TEST BBC N. A. ke 
28 DDR=8FE62: :DATREG=8FE6D 

25 vaive=127 

30 ?DDR=25SS:REM TOUTES SORTIES 
4D REPEAT 

55 ?DATREG=VALEUR 

57 PRINT VALEUR 

60 AS=GETS 

62 1F A$<)"Z" AND AS<)>"X" THEN 68 
65 IFA$="X" THEN dv=i ELSE dv=-1 
67 vaiue=VALEUR+av 

78 UNTIL(vaiue»255 OR VALEUR < @) 


Ce simple programme affecte les huit lignes du 
port utilisateur à la sortie en plaçant 255 (c’est-à- 
dire 11111111) dans le registre de direction des don- 
nées. Une valeur initiale de 127 est alors placée 
dans le registre de données du port utilisateur. 
En appuyant sur les touches Z et X, la valeur pré- 
sente dans le registre de données diminue ou aug- 
mente de façon correspondante. Le programme 
se termine lorsque la valeur du registre de don- 
nées se situe au-delà de la plage O à 255. 

En augmentant la valeur numérique présente 
dans le registre de données, nous pouvons pro- 
duire des tensions analogiques croissantes pour 
alimenter la DEL. Lorsque la tension atteint un 
niveau acceptable, la DEL commence à briller, 
la brillance maximale étant obtenue lorsque la 
valeur de 255 est présente dans le registre de don- 
nées du port utilisateur. 


Dixon 


Liz 


Kevin Jones 


EUZ 
AN 


Comme d'habitude dans ce 
type de construction, vous 
devez soigner les détails, 
surtout l'emplacement et la 
netteté des ruptures de 
pistes. Vérifiez votre travail 
avec le voltmètre; insérez 
d'abord les composants 
passifs et les liaisons de 
Sortie 1 ‘il: Soignez les soudures; 
veillez à placer 
correctement les puces. 


Circuit complet 


Port 
utilisateur 


Potentiomètre 


Câble-ruban 


Liaisons 
0000000000 


000000.0//) 


Intérieur 
du 
boîtier 


ZN425 DAC 


Condensateur 220 nF 


Liaison de fils 


Prises 


DC - DC + 


Potentiomètre 


Prise 


Liaison de fils 


NeïeNeke « 


Liaison de fils BSSOLOOIREC 


Rupture de pistes Rupture de pistes 
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2 Jeux 


Atterrissage sur CM 64 


Encore un jeu que Pierre Monsaut a écrit pour plusieurs 
micro-ordinateurs. Cette version est destinée au Commodore 64. 
Un conseil : enregistrez ce jeu sur cassette pour éviter des ennuis. 


Après un long voyage en apesanteur, poser une 
navette spatiale en douceur n’est pas chose aisée ; 
mais grâce à votre ordinateur, vous allez être en 
mesure de vous entraîner sans danger. Vous devez 
poser votre navette sur l’aire prévue à cet effet. 
Vous pouvez vous diriger vers la droite et vers 
la gauche à l’aide des touches de contrôle du cur- 
seur ou freiner votre descente avec la barre 
d’espacement. Pour réussir un atterrissage, les 
vitesses verticales et horizontales doivent être 
inférieures ou égale à 1. 


2108 POKE D+2,AH:POKE D+3,U1 
212@ POKE D,H:POKE D+1,U:POKE D+21,3 
215@ RETURN 

3000 IF ABSCH-AH)24 THEN 4000 
3005 IF UU>1 THEN 4000 

3010 IF ABSCUH)>1 THEN 4008 
3020 FOR I=1 TO 4B@8:NEXT I 
3030 SC=SC+1:GOSUB 20008 

3050 GOTO 188 

4008 POKE D+5,U+5:POKE D+4,H 
4020 POKE D+21,6 


S REM  XXXXXXMAMXMRAMXX 450@ PRINT:PRINT:PRINT:PRINT:PRINT 
10 REM x ATTERRISSAGE x 4530 PRINT TABC6)D'UOTRE NAUETTE S'EST EC 
45 REM XXXXXXXXXXXXEXNXX RASEE 
28 GOSUB 12008 454@ IF SCDRE THEN RE=SC 
109 GET X$:IF FU-Q THEN 150 4545 FOR 1=1 TO 2@@8:NEXT I 
110 IF X$<>'" THEN FU=FU-1 456@ PRINT:PRINT:PRINT 
12@ IF X$=" “ THEN UU=UU-1 458@ PRINT TABC13)"SCORE : "; SC 
130 IF X$-G$ THEN UH=UH-1 4598 SC=8 
14@ IF X$=D$ THEN UH=UH+1 5088 PRINT:PRINT:PRINT 
158 UU=UU+0. 1: U=U+UU: H=H+UH 5038 PRINT TAB(13)"RECORD :';RE 
190 IF H>255 THEN H=2:MS=MI1 5048 IF RE<SC THEN RE=SC 
208 IF H>9@ AND MS=M1 THEN 4540 5058 SC=2:PRINT:PRINT:PRINT:GET X$ 
21@ IF H<@ AND MS=M1 THEN H=255:MS=M2 5108 PRINT TABC13)J"UNE AUTRE ?" 
220 IF H<@ AND MS=M2 THEN 4548 5110 GET X$ 
24@ PRINT HO$; 5120 IF X$="" THEN 5110 
25@ PRINT “CARBURANT : “3; STR$CFU J; * 5130 IF X$<>'N" THEN POKE D+21,@:GOTO 28 
255 IF U<@ THEN 308 514@ END 
268 POKE D+16,MS:POKE D,H 10008 DATA @,255,0,1,255,128,3,255,192 
27@ POKE D+1,INTCU) 10819 DATA 7,255,224,12,195,48,12,195,48 
273 16 UDUI- —-3 THEN 3900 10828 DATA 15,255,240,12,182,48,12,102,4 
38Q PRINT "UITESSE VERT. : "; STR$CINTC18x 8 
UU)/18);" 18938 DATA 15,255,240,7,255,224,3,129,19 
31@ PRINT “UITESSE HORIZ.: ";STR$CUH ); 2 

” 10048 DATA 1,129,128,0,255,0,1,255,128 
3206 GOTO 108 19058 DATA 1,24,128,2,60, 64, 2, 36, 64 
1000 D-53248:RESTORE 10868 DATA 4,8 ,32,4,0.32, 14:0,112,8 
121@ FOR I-@ TO 198 18108 DATA 8.0. 8,0,0,0,0,0,0,0,0,0,0,0,0 
192@ READ A:POKE 832+I,A 19110 DATA 0,0,0,0,0,80,0,0,0,0,0,0,0,0,0 
1935 NEXT I 10120 DATA 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 
1940 M1=5:M2-2:POKE D+39,7:POKE D+40,7 10130 DATA 0,8,0,0,0,0,0,8,0,255,255,255 
1890 POKE D+41,0:POKE 2940,13 10148 DATA 255,255,255,255,255,255,0 
1110 POKE 2041,14:POKE 2842,15 10208 DATA 0,8,8,0,0,45,0,27,3,0,0,8,0,1 
1130 U1-230:00-0:FU=98:G$=CHR$C29) 27,0 
1170 D$=CHR$C17 ):HO$=CHR$C19):M=54272 18218 DATA 0,5,0,0,236,0,0,67,0,2,64,249 
2008 PRINT CHR$(147);:POKE D+21,0 19228 DATA 7,32, 112, PE 32, 56, 19, 145, 56 : 
202@ H=INTCRNDCTI 2x191 }+65 19238 DATA 31,23,120,31,25,124,95,97,254 
203@ AH=INTCRNDCTI 3x191 +65 18240 DATA 127,255,254,255,255,255,255 
2050 FU=FU+108:MS=M0:UH=2: UU=B:U-0 10258 DATA 255,255,0,0,0,0,0,8,0,0,0 
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Libre transfert 


En approchant de la fin de notre cours, nous abordons des 
techniques plus générales : le code translatable, les longueurs 
d'instructions et les routines de synchronisation. 


Un programme écrit à l’aide de code translata- 
ble, ou indépendant de la position, peut être placé 
en n’importe quelle position de mémoire et exé- 
cuté sans nécessiter aucune modification. C’est 
particulièrement important dans les systèmes 
multitâches ou multi-utilisateurs, où plusieurs 
programmes peuvent être chargés en mémoire en 
même temps, à l’endroit le plus approprié. Même 
dans des systèmes plus simples, à un utilisateur, 
il est généralement important de pouvoir dispo- 
ser de bibliothèques de sous-programmes et de 
construire un programme à partir de modules 
autonomes, la position d’une routine en mémoire 
pouvant varier. 

La plupart des processeurs règlent cette ques- 
tion à l’aide de ce qu’on appelle un chargeur- 
éditeur de lien. L’assembleur produit un code 
translatable, qui exclut toute référence à des 
adresses réelles en mémoire; c’est le rôle du 
chargeur-éditeur de lien d’insérer les adresses en 
chargeant le programme en mémoire. Puisque 
c’est le chargeur lui-même qui manie les adres- 
ses, il est simple de s’assurer que les transferts 
de contrôle entre différents modules sont correc- 
tement traités. 

Ainsi, des parties de code peuvent être écrites 
en différents langages qui sont tous compilés ou 


Le lien manquant 


DÉCLARATION DE 
ROUTINES EXTERNES 


assemblés pour former le même code transla- 
table; par exemple, des programmes en PASCAL 
peuvent appeler des routines de bibliothèque en 
FORTRAN. 

Cette approche peut aussi être utilisée avec le 
6809, et, en fait, elle est nécessaire si l’on emploie 
une construction modulaire. Le 6809 facilite ce 
processus en autorisant à écrire directement un 
code translatable. 

La clé pour écrire un code translatable consiste 
à se référer à toutes les adresses au moyen d’un 
décalé (offset) du compteur de programme (PC). 
Il existe pour un programme deux moyens d’uti- 
liser une adresse : comme donnée et comme des- 
tination pour un transfert de contrôle. 

Les instructions de branchement (BRA, BSR, 
etc.) calculent leurs destinations comme décalés 
du PC, et pourraient servir à tous les transferts 
de contrôle à l’intérieur du programme utilisa- 
teur. Les instructions de transfert absolu (JMP et 
JSR) ne devraient être utilisées que pour des des- 
tinations qui seront toujours au même endroit en 
mémoire, comme le sont les routines de système 
d’exploitation. 

Le plus difficile est de rendre indépendantes 
toutes les références à une position de donnée, 
et le 6809 y arrive en permettant d’utiliser le PC 


PROGRAMME EXÉCUTABLE 


BIBLIOTHÈQU 
DE DISQUES 


Chargeur-éditeur de lien 
Dans de grands systèmes, 
les programmes en langage 
machine sont en fait 
chargés en mémoire par le 
chargeur-éditeur de lien. 
Cette utilité du système 
d'exploitation prend le 
code machine semi- 
assemblé (ne contenant 
pas d'adresses absolues) 
à partir de l’assembleur, 
et détermine la meilleure 
adresse ORG à partir de 
l’état du système. Il utilise 
cette adresse pour 
remplacer les adresses 
symboliques, que 
l’assembleur a laissées 
dans le programme, par 
des adresses absolues 
puis lie au programme 
toutes les routines de 
bibliothèque nécessaire au 
programmeur; ces routines 
sont chargées à partir du 
disque de bibliothèque et 
attachées au programme. 
Leurs adresses d'appel 
absolues peuvent ensuite 
remplacer les adresses 
symboliques dans le 
programme. Enfin, le 
chargeur passe la totalité 
du programme au système 
d'exploitation pour 
l'exécution. 

(CI. Liz Dixon.) 
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pour l’indexation. L’instruction : 
LDA OFFSET,PC 


additionnera le décalé (signé) à la valeur actuelle 
du PC pour obtenir l’adresse effective. Le pro- 
blème avec ce mode d’adressage est de savoir 
comment calculer correctement le décalé : il faut 
calculer la différence entre l’adresse de la don- 
née et la valeur actuelle du PC, en se souvenant 
que le PC est incrémenté dès qu’une instruction 
est chargée dans le processeur. Lorsque l’on exé- 
cute l'instruction, le PC pointe donc l’instruction 
suivante. 

Cette méthode est compliquée par l’ampleur 
des variations de longueur des instructions 6809 
— de 1 à 5 octets de longueur. Par exemple : 


LDX OFFSET,Y 


prend 1 octet pour l’opc et 1 octet pour l’après- 
octet, qui est utilisé pour toute instruction indexée 
pour spécifier le registre d’index qui est pris en 
compte. Le décalé peut prendre 1, 2 ou 3 octets, 
suivant sa taille. Les décalés nuls et des décalés 
exprimés en 5 bits peuvent être incorporés dans 
l’après-octet (bien que certains assembleurs ne 
puissent pas manier cela très précisément). Les 
décalés supérieurs requièrent un octet supplémen- 
taire (s’ils peuvent s’exprimer en 8 bits) ou 
2 octets supplémentaires. Des décalés de 0 ou 
5 bits ne sont pas autorisés lorsque le PC est uti- 
lisé pour l’indexation. L’instruction : 


LDY OFFSET,X 


nécessite déjà un autre octet supplémentaire parce 
que l’opc pour LDŸ a 2 octets de longueur. 

La plupart des assembleurs utilisent la nota- 
tion spéciale PCR (compteur de programme rela- 
tif), qui fait que l’assembleur se sert du PC 
comme d’un registre d’index et calcule le décalé. 
Par exemple : 


DATITM FCB 0 


LDA DATITM,PCR 


Émulation de terminal 


Nous donnons un sous-programme utilisant cette 
technique pour permettre l’émulation de divers 
terminaux, de sorte qu’un programme écrit pour 
utiliser un type particulier de terminal peut tour- 
ner sur votre système. Les différences entre ter- 
minaux sont plus apparentes dans les codes 
employés pour contrôler les diverses fonctions 
d’écran, telles que l’effacement et le positionne- 
ment du curseur. Celles-ci peuvent être des codes 
de contrôle (caractères dont le code ASCII est 
inférieur à 32) ou d’échappement, consistant 
en un caractère ESCAPE (ASCII 27) suivi de 
n’importe quel autre caractère ou séquence de 
caractères. Notre simple routine ne permet que 
la substitution d’un caractère de contrôle par un 
autre, ou un seul caractère suivant ESCAPE par un 
seul autre caractère. Mais la routine montre clai- 
rement comment mener une telle émulation. On 
tient deux tables : l’une contient les caractères de 
contrôle; l’autre les caractères d'échappement. 


Si un programme sort un caractère de contrôle, 
par exemple, alors il sert de décalé dans la table 
pour trouver le caractère qui devra effectivement 
être affiché. 

Entièrement translatable, la routine peut 
s’adjoindre à tout autre programme en n’im- 
porte quelle position. Nous supposons l’existence 
d’une routine de système d’exploitation (OUTCH), 
qui envoie le caractère dans l’accumulateur A 
vers l’écran, et nous utilisons JMP pour accéder 
à cette routine — qui doit se trouver dans une 
position fixe de la mémoire. Notez que la direc- 
tive ORG doit toujours être donnée, bien qu’elle 
n’ait pas d’effet. Le caractère à afficher doit se 
trouver en A. 


Longueurs d'instructions 


Le problème du calcul de la longueur des instruc- 
tions n’est pas restreint à l’usage de l’adressage 
« compteur de programme relatif ». Il est sou- 
vent nécessaire de connaître la longueur totale 
d’une routine à insérer dans un espace mémoire 
restreint — par exemple dans une ROM. Tout 
ouvrage relatif au langage d'assemblage 6809, ou 
au manuel d’assembleur, doit inclure une table 
des mnémoniques associés aux données. Pour 
chaque mnémonique, cette donnée inclura un opc 
correspondant, la longueur totale de l’instruction 
(bien que cela puisse ne pas être possible, auquel 
cas la longueur minimale sera donnée, suivie d’un 
signe +), le nombre de cycles d’horloge nécessité 
par l’instruction, et l’effet de l’instruction sur les 
drapeaux de code condition. 

Les règles générales pour calculer les longueurs 
d’instructions — et donc pour écrire un code 
compact — sont les suivantes : 

1. La plupart des opc sont à un octet; ils affec- 
tent directement le contenu de $ et Ÿ (sauf LEA) 
et certains, qui affectent U (comme LDY et STS), 
ont 2 octets de longueur. 

2. Toute adresse indexée nécessitera l’utilisation 
d’un après-octet, et éventuellement de 1 ou de 
2 octets supplémentaires. Cela dépendra de la 
taille du décalé. 

3. Les données suivant l’opc en mode immédiat 
ont 1 ou 2 octets de longueur, selon la taille du 
registre utilisé. 

4. Les adresses doivent avoir 1 octet de longueur 
en mode page directe (généralement des empla- 
cements compris entre 0 et $FF), et sinon 2 octets. 
Tous les assembleurs n’utilisent pas convenable- 
ment l’adressage direct ; ainsi, une adresse peut 
être transformée en 2 octets alors qu’on n’en 
attendait qu’un. 

Le problème du calcul du temps pris par cha- 
que instruction est également compliqué, ne 
serait-ce que parce que ce temps dépend du nom- 
bre d’octets qui doivent être cherchés, c’est-à-dire 
de la longueur de l'instruction. 

C’est important dans les applications en temps 
réel et pour la conduite de certains périphériques. 
Le temps pour chaque instruction est donné par 
le nombre de cycles d'horloge — ou, du moins, 
le nombre minimal de cycles d’horloge — que 
prend l'instruction; ainsi, le temps pris dépen- 


dra aussi de la fréquence d’horloge. Pour un 
système 6809, on a couramment 1 MHz — un 
million de cycles par seconde. Chaque cycle 
d’horloge prend donc un millionième de seconde. 
La simple instruction : 


LDA DATITM 


qui utilise une adresse 16 bits prend cinq cycles, 
et s’exécute donc en 5 millionièmes de seconde. 
L'’instruction : PSHS PC,B,CC prend cinq cycles plus 
un pour chaque octet entré sur la pile; soit dans 
ce cas, un total de neuf cycles (souvenez-vous que 
le PC a 2 octets). 

Si un système n’inclut pas une horloge temps 
réel, alors le seul moyen de mesurer le temps 
écoulé est une routine de retard logiciel. Celle-ci 
exécute une séquence d’instructions dont les 
temps individuels doivent être choisis de telle 
sorte que la somme donne l’intervalle requis. De 
tels intervalles sont habituellement mesurés en 
millisecondes (millièmes de seconde), et il n’est 
donc pas nécessaire d’être trop exact — une dif- 
férence d’un millionième de seconde n’importera 
pas. En supposant une fréquence d’horloge de 
1 MHZ, la routine de retard logiciel que nous 
donnons ici produira des retards compris entre 
1 et 255 millisecondes : le nombre exact de milli- 
secondes (ms) étant passé comme paramètre dans 
A. La notation (A) signifie le contenu de l’accu- 
mulateur A. 

Le calcul pour trouver la constante COUNT peut 
s’exprimer comme suit : 


TEMPS 
PRIS 
(CYCLES 
D'HORLOGE) 


NOMBRE NOMBRE 


Los con | 
Ds 


PULSPCBCC Î9 


Cela donne un total de (A)'{7+5"COUNT)+16 cycles 
d’horloge. Pour faciliter le calcul, nous ignore- 
rons 16. A une fréquence d’horloge de 1 MHz, 
il y a 1 000 cycles d’horloge dans une milli- 
seconde, donc le temps total sera : (A)'1000 cycles 
d’horloge. 


(A)*(7+5*COUNT) = (A)*1000 
(7+5*COUNT) = 1000 
B'COUNT =973 
COUNT = 195 (arrondi à l'entier le plus proche). 


Il est tout à fait possible de prendre des retards 
plus précis et d’utiliser les registres 16 bits pour 
un plus grand intervalle, mais le principe de 
décrémentation d’un registre, un nombre fixe de 
fois, reste le même. 


Langage machine } 


Routine d'émulation de terminal 


ESCAPE EQU 27 
SPACE EQU 32 (L'espace est ASCII 32) 
OUTCH EQU Entrer ici l'adresse du 
système d'exploitation. 
ORG $1000 
C 
CTABLE RMB 3 ne tue 
ETABLE RMB 128 de de 
chappement. 
EFLAG FCB 0 Drapeau indiquant si le 
dernier caractère était 
ESCAPE. 
DISPCH PSHS X Sauvegarde x. 
TST EFLAG, PCR Vérifie si le dernier 
caractère était ESCAPE. 
BEQ DISP1 Si pas ESCAPE, alors va en 
DISP. 
Si d ad 
LEAX ETABLE, PCR TABLE ee e resse de 
LDA A,X Prend caractère de remplacement 
utilisant le caractère 
original en À comme décalé. 
CLR EFLAG, PCR Réinitialise EFLAG. 
BRA FINISH 
Vérifie si tère d 
DISP1 CMPA SPACE tbe ds SICILE 
BGE FINISH Si pas caractère de 
contrôle, alors va en FINISH. 
CMPA ESCAPE Sinon vérifie si ESCAPE. 
BEQ ESCCH : c'est ESCAPE, alors va en 
ESCCH. 
LEAX CTABLE,PCR Prend l'adresse de CTABLE en X. 
LDA A,X Prend caractère de 
remplacement en utilisant 
le ingheris pe en A 
BRA FINISH Jia 
ESCCH INC EFLAG,PCR Met EFLAG pour indiquer que 
c'était un caractère 
d'échappement. 
FINISH PULS X Restaure X. 
JMP OUTCH Affiche caractère en A. 
END Notez que le RTS à la fin de 
OUTCH redonne le contrôle 
au programme appelant. 
: AE Sous-programme pour 
Routine de retard logiciel retarder de (A) 
COUNT EQU 195 Voit calcul. 
ORG $1000 
DELAY PSHS B,CC Sauvegarde les deux autres 
registres affectés. 
LOOP1 LDB #COUNT Compte 1 ms. 
LOOP? DECB Continue à décrémenter. 
BNE LOOP? Jusqu'à ce que 8 devienne 
nul. 
DECA pe gt À après 
ms. 
BNE LOOP1 Jusqu'à . que A devienne 
PC,B,CC Retour. 
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L’œil du droïde 

Ces deux images 
extraites de Psytron 
correspondent au premier 
niveau du jeu. A mesure 
que le droïde pourchasse 
le saboteur à travers les 
corridors, la vue 
d'ensemble se modifie; 
une fenêtre (en bas et à 
droite de l'écran) permet 
au joueur de « voir » à 
travers les yeux du 
droïde. Lorsque le 
saboteur est enfin repéré 
(image de droite), il peut 
être détruit par simple 
pression sur le bouton de 
mise à feu. 

(CI. Spectrum.) 
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Attaque psychique 


Les jeux d’arcades de type « combats galactiques » sont en perte de 
vitesse. Aujourd’hui, les logiciels à succès mêlent des éléments très 
divers : arcades, stratégie, et même jeu d’aventures. 


Psytron est un jeu aussi complexe que passion- 
nant ; le graphisme en est remarquable, et vous 
aurez besoin de bien du temps avant de vous en 
rendre maître. 

Vous jouez le rôle de Psytron, organisme mi- 
humain, mi-informatisé, qui contrôle une colo- 
nie spatiale sur la planète Betula 5. 

Elle comprend divers bâtiments, dont chacun 
a une fonction spécifique : c’est ainsi que les 
systèmes de culture hydrologiques sont vitaux 
pour les colons, tandis que les installations pro- 
ductrices d’énergie permettent à l’ordinateur de 
fonctionner. La colonie serait sans défense si la 
principale d’entre elles était mise hors d’usage. 
L'emploi des touches du clavier, ou d’un man- 
che à balai, donne au joueur une vue à 360° de 
toutes les différentes constructions; le graphisme 
est très soigné et donne à l’ensemble une allure 
vraiment réaliste. 

A chaque niveau du jeu, Psytron ressemble de 
très près à ce que proposent habituellement les 
jeux d’arcades. Le joueur dispose de plusieurs 
armes de façon à parer aux coups des envahis- 
seurs étrangers. Ce n’est qu’au quatrième niveau 
que les éléments stratégiques du jeu commencent 
à devenir véritablement apparents. 

Au premier niveau de jeu, Psytron contrôle un 
« droïde », dont le rôle est de détruire des sabo- 
teurs tripodes envoyés par l’ennemi pour endom- 
mager les installations de la base. 

Au deuxième et au troisième niveau, vous 
devrez faire face aux soucoupes volantes de 
l’adversaire : vous pourrez les abattre une par 
une, ou faire usage du « disrupteur », qui anni- 
hile tous les appareils en vue; mais il est instable 
et a environ une chance sur dix d’exploser quand 
il est mis en service. 

Parvenu au quatrième niveau, vous serez 
amené à faire certains choix stratégiques, en fonc- 
tion des destructions imposées à vos installations. 


Les extraterrestres ne cessent d’attaquer les points 
vitaux de votre base et de lancer des saboteurs 
dans des missions-suicides ; mais c’est ici qu’inter- 
vient l’option Freezetime, qui vous permet de 
« geler » l’action par simple appui de la touche 
RETURN. Vous recevez alors des rapports qui vous 
renseignent sur les dommages qui vous ont été 
infligés. Vous aurez à prendre en compte le nom- 
bre d’hommes d’équipage tués ou blessés, les 
approvisionnements qui vous restent, et l’état de 
l’usine productrice d’énergie. Vous pourrez pro- 
céder à des réparations et affecter vos hommes 
aux endroits où ils seront le plus efficace. Cela 
exige une répartition minutieuse des ressources 
— une équipe de réparation consomme plus 
d’oxygène et de nourriture, et il sera parfois 
nécessaire d’abandonner certains bâtiments dans 
le but de conserver assez de carburant, d’air et 
de ravitaillement. 

Au cinquième niveau, il devient possible de 
communiquer avec un vaisseau de secours, qui 
pourra vous faire parvenir ce dont vous avez 
désespérément besoin — à condition que la 
piste d’atterrissage soit encore en état de 
fonctionnement … 

Au sixième et dernier niveau, c’est l’aspect stra- 
tégique qui prend définitivement le dessus. A ce 
stade, le seul objectif est de tenir encore pendant 
une heure, et de conserver la maîtrise de la base 
en tirant parti des ressources que vous avez amas- 
sées lors des niveaux précédents. L’action s’accé- 
lère encore, les assaillants sont de plus en plus 
nombreux, et vous vous rendrez vite compte qu’il 
est impossible de tenir toutes les installations face 
à la supériorité écrasante de vos adversaires. Vous 
serez donc contraint de sacrifier certains bâti- 
ments — mais surtout pas la piste d’atterrissage, 
puisque c’est seulement par là que les secours 
peuvent vous parvenir. 

Il s’est décidément passé bien du temps depuis 
l'apparition de Space Invaders. Et Psytron, aussi 
difficile que passionnant, marque un gros pro- 
grès par rapport aux jeux d’arcades classiques qui 
ont si longtemps dominé le marché. 
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